<template>
	<view class="bg-[#f8f8f8] min-h-[100vh]" :style="themeColor()">
		<block v-if="!loading">
			<view class="flex items-center order-bg-wrap p-[40rpx]">
				<image class="w-[90rpx] h-[90rpx] rounded-full mr-[20rpx]" v-if="fenxiaoInfo.member && fenxiaoInfo.member.headimg" :src="img(fenxiaoInfo.member.headimg)" mode="aspectFill"></image>
				<image class="w-[90rpx] h-[90rpx] rounded-full mr-[20rpx]" v-else :src="img('addon/shop_fenxiao/index/head.png')" mode="aspectFill"></image>
				<view class="flex flex-col">
					<view class="flex items-center">
						<text class="truncate max-w-[380rpx] text-[#fff] mr-[10rpx] text-[28rpx]">{{fenxiaoInfo.member.nickname || fenxiaoInfo.member.username}}</text>
						<text class="text-[#fff] text-[24rpx] border-[2rpx] border-solid border-[#fff] px-[6rpx] py-[8rpx] whitespace-nowrap" v-if="fenxiaoInfo.fenxiao_level">{{fenxiaoInfo.fenxiao_level.level_name}}</text>
					</view>
				</view>
			</view>
			<view class="bg-[#fff] sticky top-[0] z-10">
				<view class="flex whitespace-nowrap justify-around overflow-hidden">
					<view class="text-center mx-[60rpx] justify-center flex flex-1 items-center h-[90rpx] border-0 border-b-[2rpx] border-solid border-[transparent]" :class="{'!border-[var(--primary-color)] text-[var(--primary-color)]': isSettlement == 1}" @click="tabChange(1)">
						<text class="text-[28rpx]">已结算</text>
						<text class="text-[28rpx]">({{moneyFormat(fenxiaoStat.fenxiao_commission)}})</text>
					</view>
					<view class="text-sm mx-[60rpx] text-center justify-center flex items-center flex-1 h-[90rpx] border-0 border-b-[2rpx] border-solid border-[transparent]" :class="{'!border-[var(--primary-color)] text-[var(--primary-color)]': isSettlement == 0}" @click="tabChange(0)">
						<text class="text-[28rpx]">待结算</text>
						<text class="text-[28rpx]">({{moneyFormat(fenxiaoStat.unsettlement)}})</text>
					</view>
				</view>
			</view>
			
			<mescroll-body ref="mescrollRef" bottom="100rpx" @init="mescrollInit" :down="{ use: false }" @up="getData">
				<view class="bg-[#fff] rounded-[16rpx] p-[30rpx] sidebar-marign mt-[24rpx]" v-for='(item,index) in list' :key="index">
					<view class="flex items-center justify-between text-[28rpx]">
						<text>订单号：{{item.order_no}}</text>
						<text class="text-[var(--primary-color)]">{{item.is_settlement?'已结算':'未结算'}}</text>
					</view>
					<view class="flex pt-[40rpx]">
						<image v-if="item.order_goods && item.order_goods.goods_image_thumb_mid" class="w-[160rpx] h-[160rpx] rounded-[10rpx] shrink-0" :src="img(item.order_goods.goods_image_thumb_mid)" mode="aspectFill"></image>
						<image v-else class="w-[160rpx] h-[160rpx] rounded-[10rpx] shrink-0" :src="img('addon/shop_fenxiao/index/commission_rank.png')" mode="aspectFill"></image>
						<view class="flex flex-1 flex-col ml-[20rpx] w-[470rpx]">
							<view class="text-[28rpx] leading-[1.5]">
								<text>{{item.order_goods.goods_name.length>21?item.order_goods.goods_name.substr(0,21)+'...':item.order_goods.goods_name}}</text>
								<view class="text-[#999] ml-[10rpx] inline-block whitespace-nowrap">
									<view class="flex items-center">
										<text>(购买人：</text>
										<view class="max-w-[120rpx] truncate">{{ item.shop_order.member.nickname||'-' }}</view>
										<text>)</text>
									</view>
								</view>
							</view>
							<view class="flex items-center justify-between mt-[20rpx] text-[28rpx]">
								<text class="text-[var(--primary-color)] font-bold">￥{{moneyFormat(item.order_goods.goods_money)}}</text>
							</view>
							<view class="mt-[20rpx] text-[24rpx] text-[#999]" v-if="item.order_goods && item.order_goods.status != 1 && item.order_goods.status_name">
								{{t('refundStatus')}}{{item.order_goods.status_name}}
							</view>
						</view>
					</view>
					<view class="flex items-center justify-between mt-[40rpx] flex-wrap">
						<!-- <view class="text-[24rpx] flex items-center leading-[35rpx]">
							<text>购买人：</text>
							<text class="text-[var(--primary-color)]">{{ item.shop_order.member.nickname||'-' }}</text>
						</view> -->
						<view class="text-[24rpx] flex items-center leading-[35rpx]">
							<text>计算价：</text>
							<text class="text-[var(--primary-color)]">￥{{ moneyFormat(item.order_goods_money) }}</text>
						</view>
						<view class="flex items-center text-[24rpx] leading-[35rpx]" v-if="item.calculate_type">
							<text>{{ item.calculate_type_name }}：</text>
							<text class="text-[var(--primary-color)]">
								{{ item.calculate_type!=1 ? '￥'+moneyFormat(item.commission):item.commission_rate+'%' }}
							</text>
						</view>
						<view class="flex items-center text-[24rpx]">
							<text>佣金：</text>
							<view class="text-[var(--primary-color)]">
								{{moneyFormat(item.commission)||'0.00'}}
							</view>
						</view>
					</view>
				</view>
				<mescroll-empty :option="{'icon': img('static/resource/images/empty.png')}" v-if="!list.length && !tableLoading"></mescroll-empty>
			</mescroll-body>
		</block>
		<u-loading-page bg-color="rgb(248,248,248)" :loading="loading" loadingText="" fontSize="16" color="#333"></u-loading-page>
	</view>
</template>

<script setup lang="ts">
	import { redirect, img, moneyFormat } from '@/utils/common';
	import {ref, reactive} from 'vue'
	import { t } from '@/locale'
	import MescrollBody from '@/components/mescroll/mescroll-body/mescroll-body.vue'
	import MescrollEmpty from '@/components/mescroll/mescroll-empty/mescroll-empty.vue'
	import useMescroll from '@/components/mescroll/hooks/useMescroll.js'
	import { onPageScroll, onReachBottom } from '@dcloudio/uni-app'
	import { getFenxiaoOrder, getFenxiaoStat, getFenxiaoInfo } from '@/addon/shop_fenxiao/api/fenxiao';

    const { mescrollInit, downCallback, getMescroll } = useMescroll(onPageScroll, onReachBottom);
	
	let list = ref([]);
	let loading = ref<boolean>(true);
	let tableLoading = ref<boolean>(true);
	const getData = (mescroll) => {
		let data: object = {
			is_settlement: isSettlement.value,
			page: mescroll.num,
			limit: mescroll.size,
		};
		tableLoading.value = true;
		getFenxiaoOrder(data).then((res) => {
			let newArr = (res.data.data as Array<Object>);
			//设置列表数据
			if (mescroll.num == 1) {
				list.value = []; //如果是第一页需手动制空列表
			}
			list.value = list.value.concat(newArr);
			tableLoading.value = false;
			mescroll.endSuccess(newArr.length);
		}).catch(() => {
			tableLoading.value = false;
			mescroll.endErr(); // 请求失败, 结束加载
		})
	}
	
	// 统计
	let fenxiaoStat = ref({});
	const getFenxiaoStatFn = () => {
		getFenxiaoStat().then((res) => {
			fenxiaoStat.value = res.data;
		})
	}
	getFenxiaoStatFn();
	
	// 分销商信息
	let fenxiaoInfo = ref({});
	const getFenxiaoInfoFn = () => {
		loading.value = true;
		getFenxiaoInfo().then((res) => {
			fenxiaoInfo.value = res.data;
			loading.value = false;
		})
	}
	getFenxiaoInfoFn();
	
	let isSettlement = ref(1)
	const tabChange = (data)=>{
		isSettlement.value = data;
		list.value = [];
		getMescroll().resetUpScroll();
		getFenxiaoStatFn();
	}
</script>

<style lang="scss" scoped>
	.class-select{
		background-color: var(--primary-color);
		color: #fff;
	}
	.mescroll-body{
		min-height: calc(100vh - 350rpx) !important;
	}
	
	.order-bg-wrap {
		background: linear-gradient(to right, var(--primary-color) 40%, var(--primary-color-dark) 90%);
	}
</style>